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( 1 ): In monitor mode, breakpoints and watchpoints cannot be data-dependent. 

?): The cores have support for thread-aware breakpoints and watchpoints^v^.c^^c^VjJ-r^o enable secure 
debug on some particular threads. 
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bit 


0: halt mode 
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R/W by prograrnming the ICE by the JTAG (scanl) 
■ R/W by using MRC/MCR instruction (CP14) 


yes 


Secure debug 
enable bit 


0: debug in non- 
secure world only. 
1 : debug in secure 
world and non- 
secure world 


0 


In functional mode or debug monitor mode: R/W by 
using MRC/MCR instruction (CP 14) (only in secure 
supervisor mode) 

In Debug halt mode: No access - MCR/MRC 
instructions have any effect. 

(R/W by programming the ICE by the JTAG (scanl) 
if JSDAEN=1 


no 
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world only. 
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world 


0 


In functional mode or debug monitor mode: R/W by 
using MRC/MCR instruction (CP 14) (only in secure 
supervisor mode) 

In Debug halt mode: No access - MCR/MRC 
instructions have any effect. 

(R/W by programming the ICE by the JTAG (scanl) 
if JSDAEN=1 


no 


Secure user- 
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bit 
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possible in secure 
user mode 
1 : debug is 
possible in secure 
user mode 


1 


In functional mode or debug monitor mode: R/W by 
using MRC/MCR instruction (CP 14) (only in secure 
supervisor mode) 

In Debug halt mode: No access - MCR/MRC 
instructions have any effect. 

(R/W by programming the ICE by the JTAG (scanl) 
if JSDAEN=1 


no 
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possible for a 
particular thread 
1 : debug is 
possible for a 
particular thread 


0 


In functional mode or debug monitor mode: R/W by 
using MRC/MCR instruction (CP 14) (only in secure 
supervisor mode) 

In Debug halt mode: No access - MCR/MRC 
instructions have any effect. 

(R/W by programming the ICE by the JTAG (scanl) 
if JSDAEN=1 


no 
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meaning 


Secure debug enable 
bit 


Secure user-mode 
debug enable bit 


Secure thread-aware 
debug enable bit 


0 


X 


X 


No intrusive debug in entire secure world is possible. 
Any debug request, breakpoints, watchpoints, and other 
mechanism to enter debug state are ignored in entire 
secure world. 


1 


0 


X 


Debug in entire secure world is possible 


1 


1 


0 


Debug in secure user-mode only. Any debug request, 
breakpoints, watchpoints, and other mechanism to enter 
debug state are taken into account in user mode only. 
(Breakpoints and watchpoints linked or not to a thread 
ID are taken into account). Access in debug is restricted 
to what secure user can have access to. 


1 


i 


1 


Debug is possible only in some particular threads. In 
that case only thread-aware breakpoints and 
watchpoints linked to a thread ID are taken into account 
to enter debug state. Each thread can moreover debug 
its own code, and only its own code. 
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CP 14 bits in Debug and Status Control register 


meaning 


Secure trace enable 
bit 


Secure user-mode 
debug enable bit 


Secure thread-aware 
debug enable bit 


0 


X 


X 


No observable debug in entire secure world is possible. 
Trace module (ETM) must not trace internal core 
activity. 
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X 


Trace in entire secure world is possible 


1 




. 0 


Trace is possible when the core is in secure user-mode 
only. 


1 


• 1 


1 


Trace is possible only when the core is executing some 
particular threads in secure user mode. Particular 
hardware must be dedicated for this, or re-use 
breakpoint register pair: Context ID match must enable 
trace instead of entering debug state. 
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secure prefetch abort handler 


Software breakpoint instruction 


Non-secure prefetch abort handler 


secure prefetch abort handler 


Vector trap breakpoint 


Disabled for non-secure data abort 
and non-secure prefetch abort 
interruptions. For other non-secure 
exceptions, prefetch abort. 


Disabled for secure data abort and 
secure prefetch abort exceptions ( ! ). 
For other exceptions, secure prefetch 
abort. 


Watchpoint hits 


Non-secure data abort handler 


secure data abort handler 


Internal debug request 


Debug state in halt mode 


debug state in halt mode 


External debug request 


Debug state in halt mode 


debug state in halt mode 



■0) VftCbffflXbCf] OH vector trap register, l 

(2) Note that when external or internal debug request is asserted, the core enters halt mode and not monitor mode. 
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Software breakpoint instruction 
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Vector trap breakpoint 



Disabled for non-secure data abort and 
non-secure prefetch abort interruptions. 
For others interruption non-secure prefetch 
abort. 



Watchpoint hits 



Internal debug request 



External debug request 



Debug re-entry from system 
speed access 



(*) As substitution of BKPT instruction in secure world from non-secure world is not possible, non-secure abort 
must handle the violation. 
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